//该文件用于创建Vuex中最为核心的store
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//应用Vuex插件
Vue.use(Vuex)

//准备actions——用于相应组件中的动作
const actions = {
    // Jia(context,value){
    //     console.log('actions中的jia被调用了');
    //     context.commit('JIA',value)
    // },
    // jian(context,value) {
    //     console.log('actions中的jian被调用了');
    //     if(context.state.sum % 2) {
    //         context.commit('JIA',value)
    //     }
    // },
    jiaOdd(context,value){
        console.log('actions中的jiaOdd被调用了');
        if(context.state.sum % 2){
            context.commit('JIA',value)
        }
    },
    jiaWait(context,value) {
        console.log('actions中的jiaWait被调用了');
        setTimeout(()=>{
            context.commit('JIA',value)
        },500)
    }
}

//准备mutations——用于操作数据（state）
const mutations = {
    JIA(state,value) {
        console.log('mutations 中的Jia被调用了');
        state.sum += value
    },
    JIAN(state,value) {
        console.log('mutations 中的Jian被调用了');
        state.sum -= value
    }

}

//准备state——用于存储数据
const state = {
    sum:0 //当前的和
}


//准备getters —— 用于将state中的数据进行加工
const getters = {
    bigSum(state) {
        return state.sum*10
    }
}

//创建并暴露store
export default new Vuex.Store({
    actions,
    mutations,
    state,
    getters
})